## MIPS Opcode Reference

| Opcode             | Name                           | Action                                                                                                | Fields |    |    |                 |       |        |  |
|--------------------|--------------------------------|-------------------------------------------------------------------------------------------------------|--------|----|----|-----------------|-------|--------|--|
| Arithmetic Log     | jic Unit                       |                                                                                                       |        |    |    |                 |       |        |  |
| ADD rd,rs,rt       | Add                            | rd=rs+rt                                                                                              | 000000 | rs | rt | rd              | 00000 | 100000 |  |
| ADDI<br>rt,rs,imm  | Add Immediate                  | rt=rs+imm                                                                                             | 001000 | rs | rt | imm             |       |        |  |
| ADDIU<br>rt,rs,imm | Add Immediate<br>Unsigned      | rt=rs+imm                                                                                             | 001001 | rs | rt | imm             |       |        |  |
| ADDU rd,rs,rt      | Add Unsigned                   | rd=rs+rt                                                                                              | 000000 | rs | rt | rd              | 00000 | 100001 |  |
| AND rd,rs,rt       | And                            | rd=rs&rt                                                                                              | 000000 | rs | rt | rd              | 00000 | 100100 |  |
| ANDI<br>rt,rs,imm  | And Immediate                  | rt=rs&imm                                                                                             | 001100 | rs | rt | imm             |       |        |  |
| LUI rt,imm         | Load Upper Immediate           | rt=imm<<16                                                                                            | 001111 | rs | rt | imm             |       |        |  |
| NOR rd,rs,rt       | Nor                            | rd=~(rs rt)                                                                                           | 000000 | rs | rt | rd              | 00000 | 100111 |  |
| OR rd,rs,rt        | Or                             | rd=rs rt                                                                                              | 000000 | rs | rt | rd              | 00000 | 100101 |  |
| ORI rt,rs,imm      | Or Immediate                   | rt=rs imm                                                                                             | 001101 | rs | rt | imm             |       |        |  |
| SLT rd,rs,rt       | Set On Less Than               | rd=rs <rt< td=""><td>000000</td><td>rs</td><td>rt</td><td colspan="3">rd 00000 101010</td></rt<>      | 000000 | rs | rt | rd 00000 101010 |       |        |  |
| SLTI rt,rs,imm     | Set On Less Than<br>Immediate  | rt=rs <imm< td=""><td>001010</td><td>rs</td><td>rt</td><td colspan="4">imm</td></imm<>                | 001010 | rs | rt | imm             |       |        |  |
| SLTIU<br>rt,rs,imm | Set On < Immediate Unsigned    | rt=rs <imm< td=""><td>001011</td><td>rs</td><td>rt</td><td colspan="3">imm</td></imm<>                | 001011 | rs | rt | imm             |       |        |  |
| SLTU rd,rs,rt      | Set On Less Than<br>Unsigned   | rd=rs <rt< td=""><td>000000</td><td>rs</td><td>rt</td><td>rd</td><td>00000</td><td>101011</td></rt<>  | 000000 | rs | rt | rd              | 00000 | 101011 |  |
| SUB rd,rs,rt       | Subtract                       | rd=rs-rt                                                                                              | 000000 | rs | rt | rd              | 00000 | 100010 |  |
| SUBU rd,rs,rt      | Subtract Unsigned              | rd=rs-rt                                                                                              | 000000 | rs | rt | rd              | 00000 | 100011 |  |
| XOR rd,rs,rt       | Exclusive Or                   | rd=rs^rt                                                                                              | 000000 | rs | rt | rd              | 00000 | 100110 |  |
| XORI<br>rt,rs,imm  | Exclusive Or Immediate         | rt=rs^imm                                                                                             | 001110 | rs | rt | imm             |       |        |  |
| Shifter            |                                |                                                                                                       |        |    |    |                 |       |        |  |
| SLL rd,rt,sa       | Shift Left Logical             | rd=rt< <sa< td=""><td>000000</td><td>rs</td><td>rt</td><td>rd</td><td>sa</td><td>000000</td></sa<>    | 000000 | rs | rt | rd              | sa    | 000000 |  |
| SLLV rd,rt,rs      | Shift Left Logical<br>Variable | rd=rt< <rs< td=""><td>000000</td><td>rs</td><td>rt</td><td>rd</td><td>00000</td><td>000100</td></rs<> | 000000 | rs | rt | rd              | 00000 | 000100 |  |

mipsconverter.com/opcodes.html

| Opcode              | Name                               | Action                            | Fields | lds        |                |                |         |        |  |  |
|---------------------|------------------------------------|-----------------------------------|--------|------------|----------------|----------------|---------|--------|--|--|
| SRA rd,rt,sa        | Shift Right Arithmetic             | rd=rt>>sa                         | 000000 | 00000      | rt             | rd             | sa      | 00001  |  |  |
| SRAV rd,rt,rs       | Shift Right Arithmetic<br>Variable | rd=rt>>rs                         | 000000 | rs         | rt             | rd             | 00000   | 000111 |  |  |
| SRL rd,rt,sa        | Shift Right Logical                | rd=rt>>sa                         | 000000 | rs         | rt             | rd             | sa      | 00001  |  |  |
| SRLV rd,rt,rs       | Shift Right Logical<br>Variable    | rd=rt>>rs                         | 000000 | rs         | rt             | rd             | 00000   | 000110 |  |  |
| Multiply            |                                    |                                   |        |            |                |                |         |        |  |  |
| DIV rs,rt           | Divide                             | HI=rs%rt; LO=rs/rt                | 000000 | rs         | rt             | 000000000      |         | 011010 |  |  |
| DIVU rs,rt          | Divide Unsigned                    | HI=rs%rt; LO=rs/rt                | 000000 | rs         | rt             | 000            | 0000000 | 01101  |  |  |
| MFHI rd             | Move From HI                       | rd=HI                             | 000000 | 000000     | 00000 rd 00000 |                | 01000   |        |  |  |
| MFLO rd             | Move From LO                       | rd=LO                             | 000000 | 000000     | 0000           | 000 rd 00000   |         | 01001  |  |  |
| MTHI rs             | Move To HI                         | HI=rs                             | 000000 | rs         | 000000         | 00000          | 01000   |        |  |  |
| MTLO rs             | Move To LO                         | LO=rs                             | 000000 | rs         | 000000         | 00000000000000 |         |        |  |  |
| MULT rs,rt          | Multiply                           | HI,LO=rs*rt                       | 000000 | rs         | rt             | 000000000      |         | 01100  |  |  |
| MULTU rs,rt         | Multiply Unsigned                  | HI,LO=rs*rt                       | 000000 | rs         | rt             | rt 000000000   |         |        |  |  |
| Branch              |                                    |                                   |        | '          |                |                |         |        |  |  |
| BEQ<br>rs,rt,offset | Branch On Equal                    | if(rs==rt) pc+=offset*4           | 000100 | rs         | rt             | offs           |         |        |  |  |
| BGEZ<br>rs,offset   | Branch On >= 0                     | if(rs>=0) pc+=offset*4            | 000001 | rs         | 00001          | offs           |         |        |  |  |
| BGEZAL<br>rs,offset | Branch On >= 0 And<br>Link         | r31=pc; if(rs>=0)<br>pc+=offset*4 | 000001 | rs         | 10001          | offs           |         |        |  |  |
| BGTZ<br>rs,offset   | Branch On > 0                      | if(rs>0) pc+=offset*4             | 000111 | rs         | 00000          | offs           |         |        |  |  |
| BLEZ<br>rs,offset   | Branch On                          | if(rs<=0) pc+=offset*4            | 000110 | rs         | 00000          | offset         |         |        |  |  |
| BLTZ rs,offset      | Branch On < 0                      | if(rs<0) pc+=offset*4             | 000001 | rs         | 00000          | offset         |         |        |  |  |
| BLTZAL<br>rs,offset | Branch On < 0 And<br>Link          | r31=pc; if(rs<0)<br>pc+=offset*4  | 000001 | rs         | 10000          | offset         |         |        |  |  |
| BNE<br>rs,rt,offset | Branch On Not Equal                | if(rs!=rt) pc+=offset*4           | 000101 | rs         | rt             | offset         |         |        |  |  |
| BREAK               | Breakpoint                         | epc=pc; pc=0x3c                   | 000000 | code 00110 |                |                |         |        |  |  |
| J target            | Jump                               | pc=pc_upper <br>(target<<2)       | 000010 | target     |                |                |         |        |  |  |

mipsconverter.com/opcodes.html 2/3

|                      |                           | MIPS Opco                | ode Reference |        |          |                                         |       |        |  |
|----------------------|---------------------------|--------------------------|---------------|--------|----------|-----------------------------------------|-------|--------|--|
| Opcode               | Name                      | Action                   | Fields        |        |          |                                         |       |        |  |
| JAL target           | Jump And Link             | r31=pc; pc=target<<2     | 000011        | target |          |                                         |       |        |  |
| JALR rs              | Jump And Link<br>Register | rd=pc; pc=rs             | 000000        | rs     | 00000    | rd                                      | 00000 | 001001 |  |
| JR rs                | Jump Register             | pc=rs                    | 000000        | rs     | 000000   | 000000000000000000000000000000000000000 |       |        |  |
| MFC0 rt,rd           | Move From<br>Coprocessor  | rt=CPR[0,rd]             | 010000        | 00000  | rt       | rd 0000000000                           |       |        |  |
| MTC0 rt,rd           | Move To Coprocessor       | CPR[0,rd]=rt             | 010000        | 00100  | rt       | rd 0000000000                           |       |        |  |
| SYSCALL              | System Call               | epc=pc; pc=0x3c          | 000000        | 000000 | 00000000 | 000000 001100                           |       |        |  |
| Memory Acce          | ess                       |                          | '             | '      |          |                                         |       |        |  |
| LB<br>rt,offset(rs)  | Load Byte                 | rt=*(char*)(offset+rs)   | 100000        | rs     | rt       | offset                                  |       |        |  |
| LBU<br>rt,offset(rs) | Load Byte Unsigned        | rt=*(Uchar*)(offset+rs)  | 100100        | rs     | rt       | offset                                  |       |        |  |
| LH<br>rt,offset(rs)  | Load Halfword             | rt=*(short*)(offset+rs)  | 100001        | rs     | rt       | offset                                  |       |        |  |
| LHU<br>rt,offset(rs) | Load Halfword<br>Unsigned | rt=*(Ushort*)(offset+rs) | 100101        | rs     | rt       | offset                                  |       |        |  |
| LW<br>rt,offset(rs)  | Load Word                 | rt=*(int*)(offset+rs)    | 100011        | rs     | rt       | offset                                  |       |        |  |
| SB<br>rt,offset(rs)  | Store Byte                | *(char*)(offset+rs)=rt   | 101000        | rs     | rt       | offset                                  |       |        |  |
| SH<br>rt,offset(rs)  | Store Halfword            | *(short*)(offset+rs)=rt  | 101001        | rs     | rt       | offset                                  |       |        |  |
| SW<br>rt,offset(rs)  | Store Word                | *(int*)(offset+rs)=rt    | 101011        | rs     | rt       | offset                                  |       |        |  |

© copyright 2020 Aaron Wasserman